Vue Js Center image (Horizontally & Vertically): To align an image at the center of a Vue.js application, you can utilize CSS styles to align it both horizontally and vertically. The first method involves setting the display property of the container element to flex and using the align-items and justify-content properties to center the content.
Another approach is to use absolute positioning to center the image both horizontally and vertically in a Vue.js application. To do this, set the position property of the parent element to relative, serving as the anchor for the child element with absolute positioning. In the Vue template, create a container element that wraps the image and set its position property to relative. Then, set the image’s position property to absolute and use the top, bottom, left, and right properties to align the image both horizontally and vertically within the parent element
How to Center Align Image (Horizontally & Vertically) in Vue Js?
This is a code snippet written in Vue.js, a popular JavaScript framework for building web applications.
The Vue instance has a data
property that returns an object containing the url
property, which stores the source URL of the image that will be displayed
The HTML code within the #app
element includes a div
with a class of image-container
and an img
tag with the src
attribute bound to the url
property of the Vue instance. The width
attribute sets the width of the image to 350 pixels, and the alt
attribute specifies an alternate text description for the image.
The scoped
attribute in the style
tag limits the styles defined within it to the current component only, in this case, the #app
element. The image-container
class uses Flexbox to center the image horizontally and vertically within its container, and the img
tag has a max-width
and max-height
of 100% to ensure it does not exceed the size of its container.
Vue Js Center Image Horizonatally & Vertically Using Flex Box Example
<div id="app">
<div class="image-container">
<img :src='url' width="350" alt="Your Image">
</div>
</div>
<script type="module">
const app = new Vue({
el: "#app",
data() {
return {
url: "https://www.sarkarinaukriexams.com/images/post/1670771584desola-lanre-ologun-IgUR1iX0mqM-unsplash_(1).jpg"
}
},
})
</script>
<style scoped>
.image-container {
display: flex;
justify-content: center;
align-items: center;
height: 100%;
/* Set the height of the container to 100% of the viewport height */
border: 1px solid
}
img {
max-width: 100%;
/* Make sure the image doesn't exceed the width of its container */
max-height: 100%;
/* Make sure the image doesn't exceed the height of its container */
}
</style>
Output of above example
This code creates a container element with a height of 500 pixels and a background color of light gray. Within this container, there is an image that is positioned using absolute positioning.
The “position: absolute” property allows the image to be positioned relative to its closest positioned ancestor element. In this case, the closest positioned ancestor is the container element with “position: relative” specified.
The “top: 50%” and “left: 50%” properties position the image 50% from the top and left of the container element.
Finally, the “transform: translate(-50%, -50%)” property centers the image both horizontally and vertically by moving it up and left by 50% of its own width and height. This creates a visually centered image within the container.
Vue Js Center Image Horizontally & Vertically absolute position Example
<div id="app">
<div class="image-container">
<img :src="url" alt="Your Image">
</div>
</div>
<script type="module">
const app = new Vue({
el: "#app",
data() {
return {
url: 'https://www.sarkarinaukriexams.com/images/post/1670772103thisisengineering-raeng-yhCHx8Mc-Kc-unsplash_(1).jpg'
}
},
})
</script>
<style scoped>
.image-container {
position: relative;
/* Set the position of the container to relative */
height: 500px;
background-color: #eee;
}
img {
position: absolute;
/* Set the position of the element to absolute */
top: 50%;
/* Position the element 50% from the top of its closest positioned ancestor */
left: 50%;
/* Position the element 50% from the left of its closest positioned ancestor */
transform: translate(-50%, -50%);
/* Center the element horizontally and vertically */
width: 350px
}
</style>